#include <stdio.h>
int a[8];
void check(int i,int j)
{
	int k,out=1;
	for(k=0;k<i-1;k++)
	{
		if(a[k]==j||fabs(a[k]-j)==fabs(k-i))
		{
			out=0;
		}
	}
	return out;
}
void queen(int k)
{
	int cnt=0,i;
	if(k==9)
	{
		cnt++;
	}else
	{
		for(i=1;i<=8;i++)
		{
			if(check(k,i))
			{
				a[k-1]=i;
				queen(k+1);
			}
		}
	}
	return cnt;
}
int main()
{
	queen(1);
	return 0;
}
